home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Games of Daze
/
Infomagic - Games of Daze (Summer 1995) (Disc 1 of 2).iso
/
x2ftp
/
msdos
/
math
/
nrpas13
/
lubksb.pas
< prev
next >
Wrap
Pascal/Delphi Source File
|
1991-04-29
|
875b
|
36 lines
PROCEDURE lubksb(a: glnpbynp; n,np: integer; indx: glindx; VAR b: glnarray);
(* Programs using LUBKSB must define the types
TYPE
glnarray = ARRAY [1..n] OF real;
glindx = ARRAY [1..n] OF integer;
glnpbynp = ARRAY [1..np,1..np] OF real;
in the main routine *)
VAR
j,ip,ii,i: integer;
sum: real;
BEGIN
ii := 0;
FOR i := 1 TO n DO BEGIN
ip := indx[i];
sum := b[ip];
b[ip] := b[i];
IF (ii <> 0) THEN BEGIN
FOR j := ii TO i-1 DO BEGIN
sum := sum-a[i,j]*b[j]
END
END ELSE IF (sum <> 0.0) THEN BEGIN
ii := i
END;
b[i] := sum
END;
FOR i := n DOWNTO 1 DO BEGIN
sum := b[i];
IF (i < n) THEN BEGIN
FOR j := i+1 TO n DO BEGIN
sum := sum-a[i,j]*b[j]
END
END;
b[i] := sum/a[i,i]
END
END;